package com.atguigu.gmall.realtime.app.func;

import com.atguigu.gmall.realtime.utils.KeyWordUtil;
import org.apache.flink.table.annotation.DataTypeHint;
import org.apache.flink.table.annotation.FunctionHint;
import org.apache.flink.table.functions.TableFunction;
import org.apache.flink.types.Row;

import java.util.List;

//自定义一个UDTF函数为了让FlickSQL使用分词器的功能，作为函数
//通过注解为所有的函数的所有方法指定同一种输出类型
@FunctionHint(output = @DataTypeHint("ROW<word STRING>"))
public class keywordUDTF extends TableFunction<Row> {
    //需要去写入eval方法,此方法可以输入不同的参数进行重载
    public void eval(String text) {
        for (String keyword : KeyWordUtil.analyze(text)) {
            //输出
            collect(Row.of(keyword));
        }
    }


}
